python实现一种相似图片搜索算法

下文中介绍了一种相似图片搜索的算法,算法的思路如下:

1.把所有操作图片转换为8×8的灰度图片;

2.计算每张图片的指纹。把8x8总共64个像素点和其平均灰度值比较,大于平均值返回1,否则返回0,这样每张图都可以用64bit二进制数表示。

3.比较指定图片和搜索图片的指纹。通过汉明距来表征其差异。汉明距越大,表示这两幅图片差异越大。

代码如下,使用的python版本3.8.6

import glob
import os

from functools import reduce

from PIL import Image

EXTS = 'jpg', 'jpeg', 'JPEG', 'gif', 'GIF', 'png', 'PNG'

def avhash(im):
    if not isinstance(im, Image.Image):
        im = Image.open(im)
    im = im.resize((8, 8), Image.ANTIALIAS).convert('L')
    avg = reduce(lambda x, y: x + y, im.getdata()) / 64.
    tmp_a = map(lambda i: 0 if i < avg else 1, list(im.getdata()))
    tmp_b = list(tmp_a)
    i = 0
    c = 0
    for dt in tmp_b:
        c = c + (dt << i)
        i = i +1
    return c

def hamming(h1, h2):
    h, d = 0, h1 ^ h2
    while d:
        h += 1
        d &= d - 1
    return h

if __name__ == '__main__':
    h = avhash("cat.jpg")
    wd = "cat"
    os.chdir(wd)
    images = []
    for ext in EXTS:
        images.extend(glob.glob('*.%s' % ext))

    seq = []
    for f in images:
        seq.append((f, hamming(avhash(f), h)))

    for f, ham in sorted(seq, key=lambda i: i[1]):
        print ("%d\t%s" % (ham, f))

 

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
选择性搜索(Selective Search)算法是一种用于目标检测的启发式算法,它通过分割图像为小块,然后逐步合并这些小块以获取所需的子块。在经典的目标检测模型R-CNN中,选择性搜索算法被用于生成模型的候选区域。 以下是选择性搜索算法Python实现解释: 1. 划分区域:将图像划分为多个小区域。 2. 特征提取:对每个小区域提取纹理特征和颜色特征。 3. 生成区域集R:根据特征相似度计算,将相似的小区域合并成更大的区域,并将这些区域加入到区域集R中。 4. 相似度计算:计算不同区域之间的相似度,常用的相似度计算方法有纹理特征相似度和颜色特征相似度。 5. 判断并获取相邻区域:根据相似度计算结果,判断哪些区域是相邻的,并获取相邻区域的集合。 6. 合并区域:将相邻的区域合并成更大的区域。 7. 选择性搜索算法:重复执行步骤4-6,直到得到所需的子块。 以下是一个简单的选择性搜索算法Python实现示例: ```python # 导入所需的库 import cv2 import selectivesearch # 读取图像 image = cv2.imread('image.jpg') # 运行选择性搜索算法 selective_search = selectivesearch.selective_search(image, scale=500, sigma=0.9, min_size=10) # 获取候选区域 regions = selective_search['rects'] # 打印候选区域 for (x, y, w, h) in regions: print("候选区域:", (x, y, w, h)) ``` 这段代码使用了OpenCV库中的selectivesearch模块来实现选择性搜索算法。首先,读取图像并运行选择性搜索算法。然后,获取候选区域并打印出来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值